A Proof of the Loehr- Warrington Amazing TEN to the Power n Conjecture 



Shalosh B. EKHAD 1 , Vince VATTER 1 , and Doron ZEILBERGER 1 

Theorem: There are 10 n words in the alphabet {3, —2} of length 5n, sum 0, and such that every 
factor that sums to and that starts with a 3 may not be immediately followed by a —2. 



Proof: 1. Download Maple package TEN from http : //www . math . rutgers . edu/~zeilberg/tokhniot/TEN| . 



Save it as TEN. 2. Go into Maple, and type: read TEN: . 3. Let your computer rediscover a (linear) 
grammar for these words, by typing G : =DiscoverGrammar (3 , 2 , 3) : (if you actually want to see it 
replace the : by ; ). 4. To prove (rigorously!) that the conjectured grammar G indeed describes 
(unambiguously!) our language, type: ProveGrammar32(G,3) ; and get the output true. 5. To 
get the weight-enumerator for the language (where the weight of a word w is x len9tfl ( w '), type 
GFgrammar (G,x) ; and get the output 1/(1 — 10x 5 ). □ (endproof) □ (endpaper) 

Appendix: TEN Remarks for Human Readers 

1. The Theorem was conjectured by Nick Loehr and Greg Warrington, in a more general setting, 
where 3 and —2 are replaced by general relatively-prime positive and negative integers, a and —b, 
5n is replaced by (a + b)n, and 10" is replaced by ( a ~^ b ) • The general case is still open. Greatly 
inspired by our proof, Loehr and Warrington, together with Bruce Sagan, found a computer-free 
proof of our theorem. They then extended their approach to prove it for 6 = 2 and all odd a. 
This will appear in their forthcoming paper "A Human Proof for a Generalization of Shalosh B. 
Ekhad's 10 n Lattice Paths Theorem." We wish to acknowledge stimulating discussions with these 
three humans, and of course we thank Nick and Greg for conjecturing such a beautiful result in the 
first place, and Bruce for telling Vince, who told Doron, who told Shalosh. 

2. The Maple package TEN that (automatically!!) discovered the grammar, and then (automat- 
ically!!!) proved its correctness, and then (automatically!) computed the weight-enumerator, was 
written by VV and DZ. It was executed by SBE. 

3. For a blow-by-blow description of how the grammar was discovered, type 
G : =DiscoverGrammarVerbose (3 ,2,3): . 

(The output file may be viewed/downloaded at rttp : //www . math . rutgers . edu/~zeilberg/tokhniot/oTENdgv| . ) 



4. People with no access to Maple may view the output at 



http : //www .math, rutgers . edu/~zeilberg/tokhniot/ oTEN32t 



http : //www. math. rutgers . edu/~zeilberg/tokhniot/ oTEN32v, 



^ Department of Mathematics, Rutgers University (New Brunswick), Hill Center-Busch Campus, 110 Frelinghuysen 
Rd., Piscataway, NJ 08854-8019, USA. [ekhad, vatter, zeilberg] at math dot rutgers dot edu , 



http : //www. math. rutgers . edu/~ [zeilberg/ekhad. html , vatter, zeilberg] . First version: Sept. 14,2005. Ac- 



companied by Maple package TEN downloadable from Zeilberger's website. Supported in part by the NSF. 
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and 



tittp : //www .math. rutgers . edu/~zeilberg/tokhniot/oTEN32vv 



for the terse, verbose, and very verbose 



versions. 

5. The best way to understand the heuristics behind the act of discovery (of the linear grammar 
for the language of the theorem) and the logic behind the act of verification (proving rigor- 
ously that the empirically-conjectured grammar is indeed correct) is to carefully read the Maple 
source-code, generously made available by the authors, free of charge, even though the same 
methodology is very likely to solve other problems. There are ample comments, and readers are 
encouraged to experiment with TEN themselves. A nice exercise would be to type DiscoverGram- 
mar(l, 1,3) ; for the grammar of the language of zero-sum words in { — 1, 1} that avoid factors of 
the form 1 [ — 1] ( — 1) , where [—1] denotes a word that sums up to —1. Then prove its validity by 
human means. 

6. What if you don't know Maple well enough to follow someone else's code? Then go and learn 
Maple! It would be time much better spent than reading esoteric papers like this one. 

7. Having said that, as a concession to Maple-illiterate people, let us briefly describe the method- 
ology of discovery, to be followed by a description of the methodology of proof. 

Procedure Corpus first generates all the words of our language up to a specified length. For any 
language L in the alphabet {a, —b}, and any pair of words in that alphabet (not necessarily in L), 
[wi,W2], let L(wi,W2) be the subset of L consisting of those words of the form W1UW2 for some 
word u. We want to construct a binary family tree, rooted at L = L((p, (ft), whose vertices are pairs 
[^1,^2] that stand for L(w\, 102)- It may happen that L(u>i,W2) is empty, i.e. L has no words of 
the form W\UW2- It may also happen that such an L(w\, W2) is a clone of another L(w' 1 ,w' 2 ) , i.e. 

{v I W1VW2 £ L} = {v I W1VW2 £ L] , 

where length(wi) + length(w' 2 ) < length(wi) + lengthiwz). 

Each L[w\,W2) may be naturally partitioned in two different ways. 

L(wi, W2) = L(wia, W2) U L{w\{— b), W2) {U{w\W2}, if W1W2 £ L) , (HeadWay) 

since the letter immediately following w\ is either a or —b (assuming that the middle part is not 
null, in which case we have to add the additional singleton) or 

L{w\, W2) = L(wi, (IW2) U L{w\, (— 6)^2) {U{w\W2}-, if W1W2 £ L) , (TailWay) 

since the letter immediately preceding the W2 is either a or —b (assuming that the middle part is 
not null, in which case we have to add the additional singleton). 

Anthropomorphizing a bit, we can think of every vertex as a man who has two wives, let's call 
them Rachel and Leah. Unlike Jacob, this man doesn't decide whom he likes better until he sees 
the sons that they give him. Rachel gives birth to Joseph and Benjamin, and Leah gives birth to 
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Reuben and Simon (let's pretend that Levi et al. never got born). Now, deciding by the children's 
merit, he picks one of the wives as the main one and the other one becomes his concubine, and her 
sons get disowned. He may not mix sons! He either picks Joseph and Benjamin as heirs, or Reuben 
and Simon, but he is not allowed to pick, say, Joseph and Simon. 

Having picked Joseph and Benjamin as Jacob's legal heirs, they are now leaves in our expanding 
tree. Consider such a new vertex (that starts out as a bachelor). It may be empty, or it may 
be a clone of some older (legitimate!) relative (not necessarily a direct ancestor, e.g. Abraham 
is definitely okay, and Isaac, of course, but Essau would also do). In that case it becomes a 
permanent leaf (confirmed old bachelor), and is forbidden to have sons. But if it is neither 
empty nor a clone, then he, in his turn, has two son-pairs and he must decide which pair to pick as 
legal heirs, in other words, he has to make up his mind whether to split according to (HeadWay) 
or according to (TailWay). 

The way procedure DiscoverGrammar in our Maple package TEN decides this issue is by preferring 
those sons with congenial cardinalities, i.e. whose greatest-common-divisor with powers of ( a ^ b ) is 
as large as possible. We admit that it is only one possible heuristics for picking heirs, and its only 
merit is that it worked. The process terminates when all the leaves are either empty or clones. 

Having discovered the grammar, to find the weight-enumerator of its language, (this is imple- 
mented in procedure GFgrammar of TEN), we set up a system of linear equations, whose unknowns 
are the weight-enumerators of the L(w\, w 2 ys, let's call them z[wi,w 2 ], for all vertices [101,102] 
(both internal vertices and leaves). For each internal vertex [101,102], we have the equation 

z[wi,W2]=z[w' 1 ,W2] + z[w'{,W2] , (Internal) 

where [w[, w' 2 ], [w'{, w 2 ] are the two (legitimate!) children of [wi, w 2 \. If Wiw 2 6 L, we have to use, 
instead 

z[w 1 ,w 2 ] =z[w' 1 ,w l 2]+z[w'l,w'i}+x len ^ +len ^ . {Internal 1 ) 
For each leaf, [101,102], if it is empty, we have the obvious equation 

z[wi, W2] = , (Leaf Empty) 

while if it is a clone of [u4,io 2 ], say, then we have 

z[ Wl ,w 2 ] =,M<»i)+i™h)-i™W)-ienK) z [ 11) / )ro /] _ (LeafClone) 

Now we (or rather Maple) solve(s) this huge system of equations and get(s) the weight-enumerators 
of all vertices, in particular, z[<p, 0], our object of desire. 

8. We still need to rigorously prove that the language generated by our putative grammar is indeed 
the language of interest. Since the paternity part is obviously true, we have to prove leafness, both 
of the empty and the clone kinds. To prove that a supposedly empty leaf is indeed so, we must 
demonstrate that for each such (supposedly) empty leaf [101,102], there can never be a good word 
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(i.e. a word in L, of whatever length), of the form W\VW2- In other words we have to logically 
prove the implication: 



Every word of the form wivw 2 must be bad, i.e. contain a mishap, that is a factor of the form 
a[— a](— b). (Here, for any integer A, [A] denotes any word (in the alphabet) that adds up to A.) 

Note that if W1VW2 belongs to L then the sum of v is —A, where A := sum(wi) + sum(w2), so we 
have to prove that every word of the form w\ [— A]w2 must contain a mishap, i.e. a factor of the 
form a[—a](—b). 

The claim that vertex [101,102] is a clone of vertex [iu^u^] i s: 

u wi_vw2 is good iff Wivw'2 is good", or equivalently, 

u wivw2 is bad iff w[vw 2 is bad", 

which really contains two statements 

"if W1VW2 is bad then w^vw^ is bad", and 

"if Wivw'2 is bad then W1VW2 is bad". 

To prove such inclusions, the computer looks at all potential mishaps, which consist of an actual 
'a' in the w\ part and a potential '—6' in the v part, or a potential 'a' in the v part and an actual 
'— 6' in the W2 part. Also, conceivably (but rarely) we should consider an actual a in the w\ part 
and an actual —b in the W2 part. Each such potential mishap entails some factorization of v of the 
form L4]a[2?] or [A](— b)[B], or in the last case, just plain [A]. This is implemented (for the {3, —2} 
case) in procedure Potent ialMishaps32 of TEN. 

At the bottom line, proving that L(wi,W2) is empty boils down to proving that every word of the 
form u;i[A]iU2, where A := —(sum(wi) + sum(w2)), must contain some mishap. Also proving 
cloneship reduces to proving several statements of the form: "uiLA]u2[-B]u3 must always contain 
some mishap", where ui,U2, U3 are specific words, and [A], [B] denote arbitrary words that sum to 
A and B respectively, for some specific integers A and B. Of course, w.l.o.g. the [A] and [B] words 
are mishap-free. 

A crucial tool in the automated proof of such assertions is a recurrence that is a simple consequence 
of the Discrete Rolle Theorem: 



[A] 



\J [i-a]a[A-i], if A>0; 

(WordRecurrence) 

U [-i + b](-b)[A + i], if A<0. 



K i=l 



Indeed any word that sums to A > must have its shortest prefix whose sum is positive, the last 
letter of that prefix being, necessarily, a (or else it wouldn't be the shortest), and the sum of that 



4 



prefix (by 'continuity'!) must be between 1 and a (inclusive). Analogously, for A < 0. 

By iterating these recurrences it is easily seen that each word [A] can be written as one of several 
factorizations featuring the letters a and —b and the fundamental factors [0], [1], . . . , [b — 1]. 
We can even apply (WordRecurrence) to these, but then we'll get 'self-referential' expressions, 
i.e. ways of expressing them in terms of themselves (and the actual letters a and —b) as a kind of 
'Chomskian' grammar. 

Whenever we have to prove emptyness or cloneship, we have to prove that a certain set of words 
doesn't exist. Like in 4CT or any reducto proof (all the way back to y/2 Q), if the set was 
not empty, there would be a minimal counterexample. So it suffices to prove that minimal 
counterexamples do not exist. Note that a minimal counterexample (in our business) can never 
have a proper zero-factor (removing a zero-factor from a good word obviously results in another 
good word). So if we are in the lookout for minimal counterexamples, we can considerably reduce 
the many options that an [A] word can have, by discarding those factorizations in the enlarged 
('meta-') alphabet {a, —b, [1], [2], . . . , [b — 1]} that contain a zero-sum proper factor. Of course we 
also kick out any such meta-word that contains a mishap, i.e. a factor of the form a[—a](—b). If 
there are any survivors left after the first purge, we can replace [1], . . . , [b — 1] by their self-referential 
expressions getting longer 'meta-words', and once again discard all those that contain mishaps and 
all those that contain a zero-sum proper factor. If all goes well, nothing will be left after finitely 
many purges. For the {3, —2} case three purges sufficed to prove every instance of emptyness or 
cloneship. 

Let's explicate the above for our case of interest, a = 3, b = 2. There is only one 'meta-letter', [1], 
and we have, according to TEN (but this is so simple that even you can do it!) 

[l] = {[3,-2],[-2,3],[-2,[l],3,[l],-2]} , 

which means that every word in the alphabet {3, —2} that contains no zero-sum-factors and no 
mishaps is either the two-letter word (3) (—2) or the two-letter word (—2)3 or else can be written 
as (— 2)w\3w2(— 2), where wi,W2 are zero-sum-free and mishap-free words whose sum is 1 on their 
own right. 

We also have: 

[-l] = {[-2,[l]],[[l],-2]} , 

stating that any mishap-free and zero-factor-free word in {3, —2} that sums up to —1 may be 
written as (— 2)w\ or ioi(— 2) where w\ is a such a good word that adds up to 1. You are welcome 
to decipher the following lemmas that Shalosh discovered and proved. 

[-2] = {[-2],[[l],-2,-2,[l]]} , 

[2] = {[3, -2, [1]], [3, [1], -2], [-2, 3, [1]], [-2, [1], 3], [[1], -2, 3]} , 
[3] = {[3], [-2, [1], 3, [1]], [[1], -2, 3, [1]], [-2, 3, 3, -2, [1]], [-2, 3, 3, [1], -2], [-2, 3, -2, 3, [1]]} . 
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9. The grammar is especially simple for the case 6=1. If A a (n) is the set of good words in {a, — 1} 
we have (here 1 stands for —1) 

A a (n) = A a (n - 1) af U TA a (n - 1) aT' 1 U IL4 a (n - l)al a ~ 2 U . . . U f A a (n - 1) a , 

immediately implying that |A tt (n)| = (a + l) n . 

10. "Mr. Watson, come here. I want you!" 

While grammatically correct, this sentence is not quite Shakespeare. Its great significance is the 
way it was uttered, via the telephone, by Alexander Graham Bell. Analogously, while our proof is 
definitely closer to Gauss than Bell's sentence is to Shakespeare, its main significance, if we do say 
so ourselves, is in the way that it was discovered, and especially the way that it was proved, all 
by computer! The role of the humans (VV and DZ) is no longer that of athlete, but that of coach, 
no longer prover but programmer, or if you wish, meta-prover. We believe that this will be the 
way to go sooner than you think! Amen. 
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